package com.leetcode;

import java.util.ArrayList;
import java.util.List;


/**
 * 将一个给定字符串 s 根据给定的行数 numRows ，以从上往下、从左到右进行 Z 字形排列。
 * <p>
 * 比如输入字符串为 "PAYPALISHIRING" 行数为 3 时，排列如下：
 * <p>
 * P   A   H   N
 * A P L S I I G
 * Y   I   R
 * 之后，你的输出需要从左往右逐行读取，产生出一个新的字符串，比如："PAHNAPLSIIGYIR"。
 * <p>
 * 请你实现这个将字符串进行指定行数变换的函数：
 * <p>
 * string convert(string s, int numRows);
 *  
 * <p>
 * 示例 1：
 * <p>
 * 输入：s = "PAYPALISHIRING", numRows = 3
 * 输出："PAHNAPLSIIGYIR"
 * 示例 2：
 * 输入：s = "PAYPALISHIRING", numRows = 4
 * 输出："PINALSIGYAHRPI"
 * 解释：
 * P     I    N
 * A   L S  I G
 * Y A   H R
 * P     I
 * 示例 3：
 * <p>
 * 输入：s = "A", numRows = 1
 * 输出："A"
 */
public class N字形变换 {

    public static void main(String[] args) {
        System.out.print(convert("PAYPALISHIRING", 3));
    }


    /**
     * 给每行都创建一个StringBuilder
     *
     * @param s
     * @param numRows
     * @return
     */
    public static String convert(String s, int numRows) {

        if (numRows == 1) return s;

        int rowNums = 0;
        boolean goDown = false;

        List<StringBuilder> list = new ArrayList<StringBuilder>();

        for (int i = 0; i < numRows; i++) {
            list.add(i, new StringBuilder());
        }


        for (char c : s.toCharArray()) {
            list.get(rowNums).append(c);
            // 判断下一个字符需要向上还是向下
            if (rowNums == 0 || rowNums == numRows - 1) {
                goDown = !goDown;
            }
            rowNums += goDown ? 1 : -1;
        }

        StringBuilder builder = new StringBuilder();
        for (StringBuilder stringBuilder : list) {
            builder.append(stringBuilder.toString());
        }

        return builder.toString();
    }

}
